

#### Fixed size arrays

Size defined at compile time.

Example: int my\_array[5]; Use when size is known.



Size can change at runtime

Declared with empty brackets [].

Example: int my\_array[]; my\_array = new[10]; Use for flexible storage.

@pkpkp456 2

# Packed vs Unpacked Arrays

### Packed Array

Bit-level, all dimensions packed.

Example: logic [3:0][7:0] data; 🔷

Unpacked Array: Regular multi-

dimensional.

### **Associative Arrays**



@pkpkp456 **4** 



#### Built-in list type

Auto-resizing, operates like FIFO.

Declare: int my\_queue[\$]; ldeal for streaming.



### → SystemVerilog Array Types

Static: Fixed, no resize. Dynamic: Runtime, resizable. Associative: Sparse, resizable. Queue: FIFO, resizable.

## Packed vs Unpacked

- Packed = Bit-level
- Unpacked = Multi-dim structure.

@pkpkp456 7





Mastering them leads to clean, efficient code! Drop a \_\_\_ if you're learning SystemVerilog!